package leetcode.editor.cn;

//给你两个有序整数数组 nums1 和 nums2，请你将 nums2 合并到 nums1 中，使 nums1 成为一个有序数组。 
//
// 初始化 nums1 和 nums2 的元素数量分别为 m 和 n 。你可以假设 nums1 的空间大小等于 m + n，这样它就有足够的空间保存来自 nu
//ms2 的元素。 
//
// 
//
// 示例 1： 
//
// 
//输入：nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3
//输出：[1,2,2,3,5,6]
// 
//
// 示例 2： 
//
// 
//输入：nums1 = [1], m = 1, nums2 = [], n = 0
//输出：[1]
// 
//
// 
//
// 提示： 
//
// 
// nums1.length == m + n 
// nums2.length == n 
// 0 <= m, n <= 200 
// 1 <= m + n <= 200 
// -109 <= nums1[i], nums2[i] <= 109 
// 
// Related Topics 数组 双指针 
// 👍 802 👎 0


import java.util.Arrays;

public class MergeSortedArray {
    public static void main(String[] args) {
        Solution solution = new MergeSortedArray().new Solution();
        solution.merge(new int[]{1,2,3,0,0,0}, 3, new int[]{2,5,6}, 3);
    }
    //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
        /**
         * 核心思想 双指针 比较每一个指针的数,谁小,谁去新数组,并且进行++操作,继续上面操作
         * @param nums1
         * @param m
         * @param nums2
         * @param n
         */
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        int[] nums = new int[m + n];
        int i = 0;// num1的指针
        int j = 0;//num2的指针
        int k = 0;//nums的指针
        while (i < m && j < n){
            if (nums1[i] <= nums2[j]) {
                nums[k++] = nums1[i++];
            }else {
                nums[k++] = nums2[j++];
            }
        }

        while (i < m) {
            nums[k++] = nums1[i++];
        }

        while (j < n) {
            nums[k++] = nums2[j++];
        }

        print(nums);

    }
}

    public static void print(int[] nums) {
        System.out.println(Arrays.toString(nums));
    }
//leetcode submit region end(Prohibit modification and deletion)

}